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television guide (200) allows a timer prepro- 
gramming feature on a video cassette recorder 
(VCR) (14) to be programmed using a com- 
pressed code (102, 158, 212) of only 1 to as 
few as 7 digits, which are decoded by a decod- 
er (38) built into either the video cassette recor- 
der or a remote controller (82) to convert the 
compressed code into channel, date, time and 
length (118, 142) information. The channel, 
date, time and length information is communi- 
cated to a VCR and used to automatically acti- 
vate the VCR to record a given television pro- 
gram with the corresponding channel, date, 
time and length. Alternately, the channel, 
date, time and length information is decoded 
directly in a remote controller (80) and only 
start record, stop record and channel selection 
commands are sent to the VCR (70) at the ap- 
propriate times. The compressed codes (212) associated with each television program can be printed in a television program guide 
(200) in advance and used with a VCR or remote controller with the decoding means. The compressed codes for timer prepro- 
gramming can be utilized for just one program or repeatedly for daily or weekly use. The algorithm (100) for decoding the com- 
pressed codes can be a function of time (120, 42, 122) to ensure security of the decoding method. A method is included for use of 
the compressed codes with cable channels (176, 160, 162, 166) and a method and apparatus is described for timer preprogram- 
ming for a large number of programs (76). The coding technique can also be used for compressed coding of any multidimension- 
al vector for commercial or industrial applications. 
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APPARATUS AND METHOD FOR USING ENCODED VIDEO 
RECORDER/PLAYER TIMER PREPROGRAMMING INFORMATION 

•5 BACKGROUND OF THE INVENTION 



10 

1. Field of the Invention 

This invention relates generally to video cassette recorder 
systems and particularly to the timer preprogramming feature of 
15 video cassette recorders (VCRs) and to an apparatus and method 
for using encoded information to* shorten the time required to 
perform timer preprogramming. 

20 2. Prior Art 

The video cassette recorder (VCR) has a number of uses, 
including playing back of tapes filmed by a video camera, playing 
back of pre-recorded tapes, and recording and playing back of 
25 broadcast and cable television programs. 

To record a television program in advance of viewing it, a 
two-step process is often used: (1) obtain the correct channel, 
date, time and length (CDTL) information from a television 
30 program guide, and (2) program this CDTL information into the 
VCR. Depending on the model, year and type of the VCR, the CDTL 
information can be programmed in various ways including: (i) 
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pushing an appropriate sequence of keys in the console according 
to instructions contained in the user's manual, (ii) pushing an 
appropriate sequence of keys in a remote hand-held control unit 
according to instructions contained in the user's manual (remote 
programming) , and (iii) executing a series of keystrokes in the 
remote hand-held control unit in response to a menu displayed on 
the television screen (on-screen programming) . Other techniques 
for timer preprogramming have been suggested including: (iv) 
reading in certain bar-code information using a light pen (light 
pen programming) , and (v) entering instructions through a 
computer or telephone modem. These various methods differ only 
in the physical means of specifying the information while the 
contents , being CDTL and certain power/clock/timer on-off 
commands are generally common although the detailed protocol can 
vary with different model VCRs. Methods (i) and (ii) described 
above can require up to 100 keystrokes, which has inhibited the 
free use of the timer preprogramming feature of VCRs. To 
alleviate this, new VCR models have included an "On-Screen 
Programming" feature, which permits remote input of CDTL 
information in response to a menu displayed on the television 
screen. Generally on screen programming of CDTL information 
requires an average of about 18 keystrokes, which is less than 
some of the prior methods but still rather substantial. Some of 
the other techniques such as (iv) above , require the use of 
special equipment such as a bar code reader. 

In general the present state of the art suffers from a 
number of drawbacks. First, the procedure for setting the VCR to 
record in advance can be quite complex and confusing and 
difficult to learn? in fact, because of this many VCR owners shun 
using the timer preprogramming record feature. Second, the 
transcription of the CDTL information to the VCR is hardly ever 
error- free; in fact, many users of VCR's timer preprogramming 
features express concern over the high incidence of programming 
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errors. Third, even for experienced users, the process of 
entering a lengthy sequence of information on the channel, date, 
time and length of desired program can become tedious. Fourth, 
techniques such as reading in bar-code information or using a 
5 computer require special equipment. These drawbacks have created 
a serious impedance in the use of a VCR as a recording device for 
television programs. The effect is that time shifting of 
programs has not become as popular as it once was thought it 
would be. Accordingly, there is a need in the art for a simpler 
10 system for effecting VCR timer preprogramming which will enable a 
user to take advantage of the recording feature of a VCR more 
fully and freely. 

15 SUMMARY OF THE INVENTION 

A principal object of the invention is to provide an 
improved system for the selection and entering of channel, date, 
time and length (CDTL) information by a user required for timer 
20 preprogramming of a VCR which is substantially simpler, faster 
and less error-prone than present techniques. 

In accordance with the invention, to program the timer 
preprogramming feature of a video system, there is an apparatus 

25 and method for using encoded video recorder/player timer 
preprogramming information. The purpose is to significantly 
reduce the number of keystrokes required to set up the timer 
preprogramming feature on a VCR. In accordance with this 
invention it is only necessary for the user to enter a code with 

30 1 to 7 digits or more into the VCR. This can be done either 
remotely or locally at the VCR. Built into either the remote 
controller or the VCR is a decoding means which automatically 
converts the code into the. proper CDTL programming information 
and activates the VCR to record a given television program with 
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the corresponding channel, date, time and length- Generally 
multiple codes can be entered at one time for multiple program 
selections. The code can be printed in a television program 
guide in advance and selected for use with a VCR or remote 
controller with the decoding means. 

Other objects and many of the attendant features of this 
invention will be more readily appreciated as the same becomes 
better understood by reference to the following detailed 
descriptions and considered in connection with the accompanying 
drawings in which like reference symbols designate like parts 
throughout the figures* 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a schematic showing apparatus according to this 
invention with the code decoder means embedded in the video 
cassette recorder. 

FIG. 2 is a schematic of the VCR embedded processors for 
command control and code decoding. 

FIG. 3 is a schematic showing apparatus according to this 
invention with the code decoder means embedded in a remote 
controller. 

FIG ♦ 4 is a schematic of the processor embedded in the 
remote controller. 

FIG. 5 is a schematic of a universal remote controller with 
the code decoder means embedded in the universal remote 
controller. 
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FIG- 6 is a flow graph of the G-code decoding technique, 

FIG. 7 is a flow graph of the G-code encoding technique* 

5 FIG. 8 is an illustration of part of a television calendar 

according to this invention. 

FIG. 9 is a flowchart for decoding for cable channels. 

10 FIG. 10 is a flowchart for encoding for cable channels. 

FIG. 11. is a flow graph of the G-code decoding for cable 
channels including conversion from assigned cable channel number 
to local cable carrier channel number. 

FIG. 12 is a means for decoding including a stack memory. 

FIG. 13 is a flowchart for program entry into stack memory. 

20 FIG. 14 is a operation flowchart for sending programs from 

remote control to main unit VCR. 



15 



DESCRIPTION OF THE PREFERRED EMBODIMENTS 

25 

Referring now to the drawings , and more particularly, to 
FIG. 1, there is shown an. apparatus for using encoded video 
recorder/player timer preprogramming information 10 according to 
this invention. The primary components include a remote 
30 controller 12 and a video cassette recorder/player with G-code 
decoder 14, which can be controlled by remote controller 12 via a 
command signal 16. The remote controller 12 can have a number of 
keys, which include numerical keys 20, G-code switch 22, function 
keys 24, program key 26 and power key 27. There are means in the 
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remote controller 12 that interpret each key as it is pressed and 
send the proper command signal 16 to the VCR via an infra-red 
light emitting diode 28- Except for the G-code switch 22 on the 
remote controller 12 in FIG. 1, the remote controller 12 is 
essentially the same as any other remote controller in function. 
The G-code switch 22 is provided just to allow the user to lock 
the remote controller 12 in the G-fcode mode while using a G-code, 
which is the name given to the compressed code which is the 
encoded CDTL information, to perform timer preprogramming. 

A G-code consists of 1 to 7 digits, although more could be 
used, and is associated with a particular program. A user would 
lookup the G-code in a program guide and just enter the G-code on 
the remote controller 12, instead of the present state of the 
art, which requires that the user enter the actual channel, date, 
time and length (CDTL) commands. 

In order to understand the advantages of using a G-code, it 
is helpful to describe the best of the current state of the art, 
which is "on screen programming" with direct numerial entry. 
This technique involves about 18 keystrokes and the user has to 
keep switching his view back and forth between the TV screen and 
the remote controller while entering the CDTL information. This 
situation may be akin to a user having to dial an 18 digit 
telephone number while reading it from a phone book. The number 
of keys involved and the switching back and forth of the eye tend 
to induce errors. A typical keying sequence for timer recording 
using on-screen CDTL programming is as follows: 

PROG 2 1 15 07 30 2 08 00 2 04 PROG 

The first program (PROG) key 26 enters the programming mode. 
Then a sequence of numericals key 20 are pushed. The 2 means it 
is timer recording rather than time setting. The 1 means the 
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user is now entering the settings for program 1. The 15 is the 
date. The 07 is starting hour. The 30 is a starting minute. 
The 2 means pm. The next sequence 08 00 2 is the stopping time. 
The 04 is channel number. Finally, the PROG is hit again to exit 
5 the program mode. 

By contrast, this command could have been "coded" and 
entered in a typical G-code sequence as follows: PROG 1138 
PROG. To distinquish that the command is a coded G-code , the G- 
10 code switch 22 should be turned to the "ON" position. Instead of 
having a switch, a separate key "G" can be used. The G-code 
programming keystroke sequence would then be: G 1138 PROG. 

The use of a G-code does not preclude "on-screen" 
15 confirmation of the program information that has been entered. 
When the keystrokes "PROG 1138 PROG" are entered with the G-code 
switch in the "ON" position, the G-code would be decoded and the 
television could display the following message: 

20 PROGRAM DATE START TIME STOP TIME CHANNEL 

1138 15 7:30 PM 8:00 PM 4 

In order for the G-code .to be useful it must be decoded and 
25 apparatus for that purpose must be provided. Referring to FIG. 
1, a video cassette recorder/player with G-code decoder 14 is 
provided to be used in conjunction with remote controller 12. 
The command signal 16 sent from the remote controller 12 is 
sensed by the photodiode 32 and converted to electrical signals 
30 by command signal receiver 30. The electrical signals are sent 
to a command controller 36, which interprets the commands and 
determines how to respond to the commands. As shown in FIG. 1, 
it is also possible for the command controller 36 to receive 
commands from the manual controls 34 that are normally built into 



WO 90/07844 PCT/US89/05806 

8 

a VCR* Other possible command sources include voice if a speech 
recognizer is incorporated into the VCR and a bar code scanner. 
If the command controller 36 determines that a G-code was 
received then the G-code will be sent to the G-code decoder 38 
for decoding. The G-code decoder 38 converts the G-code into 
CDTL information, which is used by the command controller 36 to 
set the time/channel programming 40. Built into the VCR is a 
clock 42. This is normally provided in a VCR and is used to keep 
track of the date and time. The clock 42 is used primarily by 
the time/channel programming 40 and the G-code decoder 38 
functions. The time/channel programming 40 function is set up 
with CDTL information by the command controller 36. When the 
proper date and time is read from clock 42, then the time/channel 
programming 40 function turns the record/playback 44 function on 
to record. At the same time the tuner 46 is tuned to the proper 
channel in the television signal 18. 

An alternate way to control the recorder is to have the 
command controller 36 keep all the CDTL information instead of 
sending it to the time/channel programming 40.' The command 
controller would also keep track of the time by periodically 
reading clock 42. The command controller would then send 
commands to the time/channel programming 40 to turn on and off 
the recorder and to tuner 46 to cause it to tune to the right 
channel at the right time according to the CDTL information. 

The clock 42 is also an input to G-code decoder 38, which 
allows the G-code decoding to be a function of the clock, which 
lends a measure of security to the decoding technique and makes 
it harder to copy. Of course this requires that the encoding 
technique must also be a function of the clock. 

A possible realization of the command controller 36 and the 
G-code decoder 38 is shown in FIG. 2. The command controller 36 
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function can be realized with a microprocessor 50, a random 
access memory 52 and a read only memory 54, which is used for 
program storage. The input/ output 56 function is adapted to 
receive commands from the command signal receiver 30, the manual 
5 controls 34 and the clock 42, and to output signals to a display 
35, the clock 42, and the time/channel programming 40 function. 
If the microprocessor 50 interprets that a G-code has been 
received, then the G-code is sent to microcontroller 60 for 
decoding. The microcontroller 60 has an embedded random access 
10 memory 62 and an embedded read only memory 64 for program and 
table storage. The clock 42 can be read by both microprocessor 
50 and microcontroller 60. 

An alternative to having microcontroller 60 perform the G- 
15 code decoding is to build the G-code decoding directly into the 
program stored in read only memory 54. This would eliminate the 
need for microcontroller 60. Of course, other hardware to 
perform the G-code decoding can also be used. The choice of 
which implementation to use is primarily an economic one. 

20 

The blocks in Figs. 1 and 2 are well known in the prior art 
and are present in the following patents: Fields, patent no. 
4,481,412; Scholz, patent no. 4,519,003; and Brugliera, patent 
no. 4,631,601. For example, clock 42 is analogous to element 7 

25 in Scholz and element 17 in Brugliera. Other analogous elements 
are: command signal receiver 30 and Scholz 14 and Brugliera 12; 
tuner 46 and Scholz 6 and Brugliera 10; time/channel programming 
40 and Scholz 8, 11 and Brugliera 16; record & playback 44 and 
Scholz 1, 2, 4; command controller 36 and Scholz 11, 10 and 

30 Brugliera 12; microprocessor 50 and Fields- 27; RAM 62 and Fields 
34; ROM 54 and Fields 33; manual controls 34 and Scholz 15, 16; 
and remote controller 12 and Scholz 26 and Brugliera 18. 
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FIG. 3 illustrates an alternate preferred embodiment of this 
invention. In FIG. 3 a remote controller with embedded G-code 
decoder 80 is provided. The remote controller with embedded G- 
code decoder 80 is very similar to remote controller 12, except 
5 for the addition of the G-code decoder 82. Note that it is also 
possible in any remote controller to provide a display 84. The 
remote controller with embedded G-code decoder 80 would be used 
in conjunction with a normal video cassette recorder/player 70, 
which would not be required to have an embedded G-code decoder. 

10 The numerals for the subelements of video cassette 
recorder/p layer 70 are the same as described above for the video 
cassette recorder/player with G-code decoder 14 and have the same 
function, except for the absence of G-code decoder 38. This 
preferred embodiment has the advantage that it can be used in 

15 conjunction with VCRs that are presently being used. These do 
not have a G-code decoding capability. Replacing their remote 
controllers with ones that have this capability built-in can 
vastly improve the capability to do timer preprogramming for a 
modest cost. 

20 

FIG. 4 illustrates a possible realization of the G-code 
decoder 82 built into the remote controller with embedded G-code 
decoder 80. A microprocessor 60 can be used as before to decode 
the G-code r as well as interface with the display 84, a clock 85, 

25 the keypad 88 and the light emitting diode 28. Alternately, 
other hardware implementations can be used to perform the G-code 
decoding. The clock is provided in the remote controller 80 so 
that the G-code decoder 82 can be made to have the clock as one 
of its inputs. This allows the G-code decoding to be a function 

30 of the clock, which lends a measure of security to the decoding 
technique and makes it harder to copy. 

The remote controller with embedded G-code* decoder as 
described above would send channel, date, time and length 
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information to the video cassette recorder/player 70, which would 
use the CDTL information for tuning into the correct channel and 
starting and stopping the recording function. The remote 
controller may have to be unique for each different video 
5 cassette recorder/player, because each brand or model may have 
different infrared pulses for each type of information sent such 
as the channel number keys and start record and stop record keys. 
The particular infrared pulses used for each key type can be 
called the vocabulary of the particular remote controller. Each 

10 model may also have a different protocol or order of keys that 
need to be pushed to accomplish a function such as timer 
preprogramming. The protocol or order of keys to accomplish a 
function can be called sentence structure. If there is a unique 
remote controller built for each model type, then the proper 

15 vocabulary and sentence structure can be built directly into the 
remote controller. 

An alternate to having the remote controller with embedded 
G-code decoder send channel, date, time and length information to 

20 the video cassette recorder/player 70, is to have the remote 
controller with embedded G-code decoder perform more operations 
to simplify the interfacing problem with existing video cassette 
recorder/players. In particular, if the remote controller not 
only performs the G-code decoding to CDTL, but also keeps track 

25 of time via clock 85, then it is possible for the remote 
controller to send just channel, start record and stop commands 
to the video cassette recorder/player. These are usually basic 
one key commands, which means there is no complicated protocol or 
sentence structure involved. Thus, to communicate with a diverse 

30 set of video cassette recorder/player models it is only necessary 
to have memory within the remote controller, such as ROM 64 of 
FIG. 4, for storing the vocabulary for all the models or at least 
a large subset. The G-code would be entered on the remote 
controller as before and decoded into channel, date, time and 
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length information, which would be stored in the remote 
controller. Via clock 85 , the time would be checked and when the 
correct time arrives the remote controller would automatically 
send out commands to the VCR unit for tuning to the correct 
5 channel and for starting and stopping the recording. It is 
estimated that only two (2) bytes per key for about 15 keys need 
to be stored for the vocabulary for each video cassette 
recorder/player model. Thus, to cover 50 models would only 
require about 30*50 = 1500 bytes of memory in the remote 
10 controller. It would be necessary to position the remote 
controller properly with respect to the VCR unit so that the sent 
infrared signals sent by the remote controller are received by 
the unit. 

15 Another preferred embodiment is to provide a universal 

remote controller 90 with an embedded G-code decoder. Universal 
remote controllers provide the capability to mimic a number of 
different remote controllers. This reduces the number of remote 
controllers that a user needs to have. This is accomplished by 

20 having a learn function key 94 function on the universal remote 
controller , as shown in FIG. 5. If the learn function key 94 is 
pushed in conjunction with another key, the unit will enter into 
the learn mode. Incoming infra-red (IR) pulses from the remote 
controller to be learned are detected by the infra-red photodiode 

25 96, filtered and wave-shaped into recognizable bit patterns 
before being recorded by a microcontroller into a battery-backed 
static RAM as the particular IR pulse pattern for that particular 
key. This is done for all the individual keys. 

30 An example of more complex learning is the following. If 

the learn function key 94 in conjunction with the program key 26 
are pushed when the G-code switch is "ON", the unit will 
recognize that it is about to record the keying sequence of a 
predetermined specific example of timer preprogramming of the 
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particular VCR involved. The user will then enter the keying 
sequence from which the universal remote controller 90 can then 
deduce and record the protocol of the timer preprogramming 
sequence. This is necessary because different VCRs may have 
5 different timer preprogramming command formats. 

If keys are pushed without the learn function key 94 
involved, the microcontroller should recognize it is now in the 
execute mode. If the key is one of the direct command keys, the 

10 microcontroller will read back from its static RAM the stored 
pulse sequence and send out command words through the output 
parallel I/O to pulse the output light emitting diode 28. If the 
key is the PROG key and the G-code switch is "OFF", then the 
microcontroller should recognize the following keys up to the 

15 next PROG key as a timer preprogramming CDTL command and send it 
out through the light emitting diode 28. If the G-code switch 22 
is set to "ON" and the program key 26 is pushed , the 
microcontroller should recognize the following keys up to the 
next PROG key as a G-code command for timer preprogramming. It 

20 will decode the G-code into channel, date, start time and length 
(CDTL) and the microcontroller will then look up in it's static 
RAM "dictionary" the associated infra-red pulse patterns and 
concatenate them together before sending them off through the 
output parallel I/O to pulse the light emitting diode 28 to send 

25 the whole message in one continuous stream to the VCR. 

FIG. 4 illustrates a possible realization of the G-code 
decoder 92 that could be built into the universal remote 
controller with embedded G-code decoder 90. A microcontroller 60 
30 can be used as before to decode the G-code, as well as for 
interfacing with the input/output functions including the 
photodiode 96. Alternately, the G-code decoding can be performed 
with other hardware implementations. 
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The universal remote controller can also be used in another 
manner to simplify the interfacing problem with existing video 
cassette recorder/players. In particular, if the universal 
remote controller performs not only the G-code decoding to CDTL r 
but also keeps track of time via clock 85 in FIG. 4, then it is 
possible for the universal remote controller to send just 
channel, start record and stop commands to the video cassette 
recorder/player, which as explained before, are usually basic one 
key commands, which means there is no complicated protocol or 
sentence structure involved. Thus, to communicate with a diverse 
set of video cassette recorder/player models it is only necessary 
for the universal remote controller to "learn" each key of the 
remote controller it is replacing. The G-code would be entered 
on the universal remote controller as before and decoded into 
channel, date, time and length information, which would be stored 
in the universal remote controller* Via clock 85, the time would 
be checked and when the correct time arrives the universal remote 
controller would automatically send out commands to the VCR unit 
for tuning to the correct channel and for starting and stopping 
the recording. It would be necessary to po&ition the universal 
remote controller properly with respect to the VCR unit so that 
the signals sent by the universal remote are received by the VCR 
unit. 

There are a number of ways that the G-code decoding can be 
performed. The most obvious way is to just have a large look up 
table. The G-code would be the index. Unfortunately, this would 
be very inefficient and result in a very expensive decoder due to 
the memory involved. The total storage involved is a function of 
the number of total combinations. If we allow for 128 channels, 
31 days in a month, 48 oh the hour and on the half hour start 
times in a twenty four hour day, and 16 length selections in half 
hour increments, „ then the total number of combinations is 
i28x3 1x48x16 = 3,047,424. This number of combinations can be 
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represented by a 7 digit number- The address to the table would 
be the 7 digit number. In the worse case, this requires a lookup 
table that has about 4,000,000 rows by 15 to 16 digital columns, 
depending on the particular protocol. These digital columns 
5 would correspond to the CDTL information required for "on screen 
programming". Each digit could be represented by a 4 bit binary 
number. Thus, the total storage number of bits required for the 
lookup table would be about 4,000,000x16x4 * 256,000,000. The 
present state of the art has about 1 million bits per chip. 
10 Thus, G-code decoding using a straightforward table lookup would 
require a prohibitively expensive number of chips. 

Fortunately, there are much more clever ways of performing 
the G-code decoding. FIG. 6 is a flow diagram of the preferred 
15 G-code decoding technique. To understand G-code decoding, it is 
easiest to first explain the G-code encoding technique, for which 
FIG. 7 is the flow chart. Then the G-code decoding technique, 
which is the reverse of the G-code encoding will be explained. 

20 The encoding of the G-codes can be done on any computer and 

is done prior to preparation of any program guide that would 
include G-codes. For each program that will be printed in the 
guide , a channel , date , time and length ( CDTL) code 144 is 
entered in step 142. Step 146 separately reads the priority for 

25 the channel, date, time and length in the priority vector storage 
122, which can be stored in read only memory 64. The priority 
vector storage 122 contains four tables: a priority vector C 
table 124, a priority vector D table 126, a priority vector T 
table 128 and a priority vector I* table 130. 

30 

The channel priority table is ordered so that the most 
frequently used channels have a low priority number. An example 
of the data that is in priority vector C table 124 follows. 



• 
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channel 4 7 2 3 5 6 11 13 
priority 0 1 2 3 4 5 6 7 ... 

Generally the dates of a month all have an equal priority, 
so the low number days in a month and the low number priorities 
would correspond in the priority vector D table as in the 
following example. 

date 1 2 3 4 5 6 7 8 910 .. 

priority 0 1 2 3 4 5 6 7 8 9 . . 

The priority of the start times would be arranged so that 
prime time would have a low priority number and programs in the 
dead of the night would have a high priority number. For 
example , the priority vector T table would contain: 

time 6:30pm 7:00pm 8:00pm 7:30pm — 

priority O 1 2 3 

An example of the data that is in the priority vector L 
table 130 is the following: 

length of program (hours) 0.5 1.0 2.0 1.5 3.0 ... 

priority 0 1 2 3 4 

Suppose the channel date time length (CDTL) 144 data is 5 10 
19.00 1.5, which means channel 5, 10th day of the month, 7:00 PM, 
and 1,5 hours in length, then the C p ,Dp,T p ,Lp data 148 for the 
above example would be 4 9 1 3. Step 150 converts Cp f Dp f T p/ Lp 
data to binary numbers. The number of binary bits in each 
conversion is determined by the number of combinations involved. 
Seven bits for C p , which can be denoted as C 7 C 6 C 5 C 4 C 3 C 2 C lr 
would provide for 128 channels. Five bits for D p , which can be 
denoted as D5 D 4 D3 D 2 Di, would provide for 31 days in a month. 
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Six bits for T pf which can be denoted as T 6 T 5 T 4 T 3 T 2 T lf would 
provide for 48 start times on each half hour of a twenty four 
hour day. Four bits for length, which can be denoted as L 4 L 3 
L 2 Li, would provide for a program length of up to 8 hours in 
5 half hour steps. Together there are 7+5+6+4 = 22 bits of 
information, which correspond to 2**22 = 4 , 194 , 304 combinations. 

The next step is to use bit hierarchy key 120 f which can be 
stored in read only memory 64 to reorder the 22 bits. The bit 
10 hierarchy key 120 can be any ordering of the 22 bits. For 
example, the bit hierarchy key might be: 

L 8 C 3 ... T 2 C 2 T X C X L X D 5 D 4 D 3 D 2 D x 
22 21 . .. 10 987654321 



15 



Ideally the bit hierarchy key is ordered so that programs 
most likely to be the subject of timer preprogramming would have 
a low value binary number, which would eliminate keystrokes for 
timer preprogramming the most popular programs. Since all the 

20 date information has equal priority, then the D 5 D 4 D 3 D 2 D x bits 
are first. Next T 2 L x are used, because for whatever date it 
is necessary to have a time channel and length and T x C x L x are 
the most probable in each case due to the ordering of the 
priority vectors in priority vector storage 122. The next bit in 

25 the hierarchy key is determined by the differential probabilities 
of the various combinations. One must know the probabilities of 
all the channels, times and lengths for this calculation to be 
performed. 

30 For example, the probability for channels may be: 

channel 4 7 2.3 5 6 11 . 13 

priority 0 1 2 3 4 5 6 7 
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probability (%) 5 4.3 4 3 2.9 2.1 2 1.8 ... 

The probabilities for times might be: 

time 6:30pm 7:00pm 8:00pm 7:30pm ... 

priority 0 1 2 3 

probability(%) 8 7.8 6 5 

And, the probabilities for lengths might be: 

length of program (hours) 0*5 1.0 2.0 1.5 3.0 ... 

priority 0 1 2 3 4 ... 

probability (%) 50 20 15 5 4 

15 The probabilities associated with each channel, time and 

length, as illustrated above, are used to determine the proper 
ordering. Since the priority vector tables are already ordered 
by the most popular channel, time, and length, the order in which 
to select between the various binary bits for one table, for 

20 example selecting between the C7 C 6 C 5 C 4 C 3 C 2 bits, is 

already known. The C^ bit Would be selected first because as the 
lowest order binary bit it would select between the first two 
entries in the channel priority table. Then the C 2 bit would be 
selected and so on. Similarly, the T^ and bits would be used 

25 before any of the other time and length bits. A combination of 
the c lr T lr and D 5 D4 D3 D 2 bits should be used first, so 
that all the information is available for a channel, date, time 
and length. The D 5 D 4 D 3 D 2 Dj_ bits are all used because the 
date bits all have equal priority and all are needed to specify a 

30 date even if some of the bits are binary zero. 

At this point the bit hierarchy key could be: 
T l c l L l D 5 D 4 D 3 D 2 D l 
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The first channel binary bit C x by itself can only select between 
2 1 = 2 channels, and the first two channels have a probability 
percent of 5 and 4*3, respectively* So the differential 
5 probability of CI is 9.3. Similarly, the differential 
probability of T x is 8 + 7.8 = 15.8, and the differential 
probability of L 2 is 50 + 20 « 70. If the rules for ordering the 
bit hierarchy key are strictly followed, then the first 8 bits of 
the bit hierarchy key should be ordered as: 

10 

c i T l L l D 5 D 4 D 3 D 2 D l' 

because L 2 has the highest differential priority so it should be 
first, followed by T^, and then C^. 

15 

The question at that point is what should the next bit in 
the hierarchy key be: T 2 , C 2 , or L 2 . This is determined by the 
differential probabilities , which can be calculated from the 
above tables for each bit. Since we are dealing with binary 

20 bits, the C 2 in combination with C x selects between 2 2 = 4 
channels or 2 more channels over alone. The differential 
probability for C 2 is then the additional probabilities of these 
two additional channels and for the example this is: 4 + 3-7. 
In a similar manner C 3 in combination with and C 2 selects 

2 5 between 2 3 = 8 channels or 4 = 2 ( more channels over the 
combination of C x and C 2 . So the differential probability of C 3 
is the additional probabilities of these four additional channels 
and for the example this is: 2.9 + 2.1 + 2 + 1.8 « 8.8. In a 
similar manner, the differential probabilities of T 2 and L 2 can 

30 be calculated to be 6 + 5 = 11 and 15 + 5 = 20, respectively. 
Once all the differential probabilities are calculated, the next 
step is determining which combinations of bits are more probable. 
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Now for the above example , which combination is more 
probable: T 2 with C x L lf or C 2 with T x L x , or L 2 with T x C 1# 
This will determine the next bit in the key. So, which is 
greater: 11x9.3x70= 7161; 7x15.8x70= 7742; or 20x15.8x9.3= 
2938.8? In this case the combination with the greatest 
probability is 7x15.8x70= 7742 , which corresponds to C 2 with 
Li- So f C 2 is selected as the next bit in the bit hierarchy key. 

The next bit is selected in the same way. Which combination 
is more probable: C 3 with T x L lf or T 2 with or C 2 and L lf or 
L 2 with C x or C 2 and T^. For the example shown, which has the 
greatest probability* 8.8x15.8x70= 9732.8; llx(9.3+7)x70= 12551; 
or 20x(9.3+7)xl5.8= 5150.8? In this case the combination with 
the greatest probability is llx(9. 3+7) x70= 12551, which 
corresponds T 2 with C x or C 2 and So, T 2 is selected as the 

next bit in the bit hierarchy key. This procedure is repeated 
for all the differential probabilities until the entire key is 
found. 

Alternately , the bit hierarchy key can be j ust some 
arbitrary sequence of the bits. It is also possible to make the 
priority vectors interdependent, such as making the length 
priority vector dependent on different groups of channels. 
Another technique is to make the bit hierarchy key 120 and the 
priority vector tables 122, a function of clock 42, as shown in 
FIG. 7* This makes it very difficult for the key and therefore 
the coding technique to be duplicated or copied. 

For example it is possible to scramble the date bits in the 
bit hierarchy key 120 as a function of the clock* This would not 
change the effectiveness of the bit hierarchy key in reducing the 
number of binary bits for the most popular programs, because the 
date bits all are of equal priority* This could be as simple as 
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switching the D 2 and D 5 bits periodically , such as every day or 
week. Thus the bit hierarchy key 120 would switch between 

... c l T l L l D 5 D 4 D 3 D 2 D l and 

... C x T x L x D x D 4 D 3 D 2 D 5 . 

Clearly other permutations of the bit hierarchy key as a function 
of the clock are possible. 



The priority vector tables could also be scrambled as a 
function of the clock. For example, the first two channels in 
the priority channel table could just be swapped periodically. 
If this technique is followed, then the C p of 148 in FIG. 7 would 
15 change as a function of the clock 42. For example, 

channel 4 7 2 3 5 6 11 13 
priority 0 1 2 3 4 5 6 7 ... 

20 would change periodically to: 

channel 7 4 2 3 5 6 11 13 
priority 0 1 2 3 4 5 6 7 ... 

25 This would be a fairly subtle security technique, because a 

decoder that was otherwise correct would only fail if those first 
two channels were being used. Other clock dependencies are also 
possible to provide security for the coding technique. 



3 0 However it is derived , the bit hierarchy key 120 is 

determined and stored. In step 154 the binary bits of 
C p ,Dp,Tp,Lp are rearranged according to the bit hierarchy key 120 
to create one 22 bit binary number. Then the resulting 22 bit 
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binary number is converted to decimal in the convert binary 
number to decimal G-code step 156* The result is G-code 158. 

If the priority vector and the bit hierarchy key are well 
matched to the viewing habits of the general population, then it 
is expected that the more popular programs would require no more 
than 3 or -4 digits for the G-code. 

Now that the encoding technique has been explained the 
decoding technique is just reversing the coding technique. This 
is done according to the flow chart of FIG. 6. This is the 
preferred G-code decoding that can be built into G-code decoder 
38 in VCR 14 or the remote controller G-code decoders 82 and 92 
in FIGs. 3 and 5. 

The first step 102 is to enter G-code 104 . Next the G-code 
104 is converted to a 22 bit binary number in step 106. Then the 
bits are reordered in step 108 according to the bit hierarchy key 
120 to obtain the reordered bits 110. Then the bits are grouped 
together and converted to decimal form in step 112. As this 
point we obtain C p ,Dp,Tp,Lp data 114, which are the indices to 
the priority vector tables. For the above example, we would have 
at this step the vector 4 9 13. This C p ,D p ,T p ,Lp data 114 is 
then used in step 116 to lookup channel, date, time, and length 
in priority vector storage 122. The CDTL 118 for the example 
above is 5 10 19.00 1.5, which means chahnel 5, 10th day of the 
month, 7:00 PM, and 1.5 hours in length. 

If the coding technique is a function of the clock then it 
is also necessary to make the decoding technique a function of 
the clock. It is possible to make the bit hierarchy key 120 and 
the priority vector tables 122, a function of clock 42, as shown 
in FIG. 6. This again makes it very difficult for" the key and" 
therefore the coding technique to be duplicated or copied. It is 
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also possible to have the decoding and encoding techniques 
dependent on any other predetermined or preprogrammable 
algorithm. 

5 Although the above G-code encoding and decoding technique is 

a preferred embodiment, it should be understood that there are 
many ways to perform the intent of the invention which is to 
reduce the number of keystrokes required for timer 
preprogramming. To accomplish this goal there are many ways to 
10 perform the G-code encoding and decoding. There are also many 
ways to make the encoding and decoding technique more secure 
besides just making the encoding and decoding a function of the 
clock. This security can be the result of any predetermined or 
preprogrammed algorithm. 

15 

It is possible in the G-code coding and decoding techniques 
to use mixed radix number systems instead of binary numbers. For 
example, suppose that there are only 35 channels, which would 
require 6 binary bits to be represented; however, 6 binary bits 

20 can represent 64 channels, because 2 6 = 64. The result is that 
in a binary number system there are 29 unnecessary positions. 
This can have the effect of possibly making a particular G-code 
longer than it really needs to be. A mixed radix number system 
can avoid this result. For example, for the case of 35 channels, 

25 a mixed radix number system with the factors of 7 1 and 5° can 
represent 35 combinations without any empty space in the code. 
The allowed numbers for the 7 1 factor are 0, 1, 2, 3, and 4. The 
allowed numbers for the 5° factor are 0, 1, 2, 3, 4, 5, and 6. 
For example, digital 0 is represented in the mixed radix number 

30 system as 00. The digital number 34 is represented in the mixed 
radix number system as 46, because 4*7 1 +6*5° = 34. The major 
advantage of a mixed radix number system is in prioritizing the 
hierarchy key. If the first 5 channels have about equal priority 
and the next 30 are also about equal, then the mixed radix number 
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system allows the two tiers to be accurately represented. This 
is not to say that a mixed radix number system is necessarily 
preferable. Binary numbers are easier to represent in a computer 
and use of a fixed radix number system such as binary numbers 
5 allows a pyramid of prioritization to be easily represented in 
the hierarchy key. 

Another feature that is desirable in all of the embodiments 
is the capability to key in the G-code once for a program and 

10 then have the resulting CDTL information used daily or weekly. 
Ordinarily the CDTL information is discarded once it is used. In 
the case of daily or weekly recording of the same program , the 
CDTL information is stored and used until it is cancelled. The 
desire to repeat the program daily or weekly can be performed by 

15 having a "WEEKLY" or "DAILY" button on the remote controller or 
built into the VCR manual controls. Another way is to use one 
key, such as the PROG key and push it multiple times within a 
certain period of time such as twice to specify daily or thrice 
to specify weekly. For example, if the G-code switch is "ON" and 

20 the G-code for the desired program is 99 then daily recording of 
the program can be selected by the following keystrokes: 

"PROG 99 DAILY PROG" 
or by: 

"PROG 99 PROG P ROG". 

25 The G-code 99 would be converted to CDTL information, which would 
be stored and used daily in this case. The recording would begin 
on the date specified and continue daily after that using the 
same channel time and length information. A slight twist is that 
daily recording could be automatically suspended during the 

30 weekends, because most daily programs are different on Saturday 
and Sunday. 

Once a daily or weekly program is set up, then it can be 
used indefinitely. If it is desired to cancel a program and if 
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there is a "CANCEL" button on the remote controller or manual 
control for the VCR, then one way to cancel a program (whether it 
is a normal CDTL, daily or weekly entry) is to key in the 
following: 

5 "PROG xx CANCEL", where xx is the G-code. 

Again as before there are alternate ways of accomplishing this* 

If "on screen programming" is available, then the programs 
that have been selected for timer preprogramming could be 
10 reviewed on the screen. The daily and weekly programs would have 
an indication of their type. Also the G-codes could be displayed 
along with the corresponding CDTL information. This would make 
it quite easy to review the current "menu" and either add more 
programs or cancel programs as desired. 

15 

A television calendar 200 according to this invention is 
illustrated in FIG. 8. As shown, the television calendar has 
multiple day of year sections 202, multiple day sections 204, 
multiple time of day sections 206, channel indications 208, and 

20 descriptive program indications 210 arranged in a manner that is 
common in television guide publications. Arranged in relation to 
each channel indication is a compressed code 212 or G-code 
containing the channel, date, time and length information for 
that entry in the television calendar. FIG. 8 shows how easy it 

25 is to perform timer programming. All one needs to do is find the 
program one wants to watch and enter the compressed code. This 
is in contrast to having to deal with all the channel, date, time 
and length entries separately. At least the channel, date and 
time are explicitly stated in the television guide. The length 

30 is usually only available by searching the guide to find the time 
of day section 204 where a new program begins and then performing 
some arithmetic to find the length of the program. Using the 
compressed G-code .avoids all these complications. 
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For cable television programs, there is an additional issue 
that needs to be addressed for the compressed G-code to be 
useful. In a normal television guide, CDTL information is 
available for all the normal broadcast channels in the form of 
5 numbers including the channel numbers, such as channel 4 or 7* 
However, for cable channels like HBO, ESPN etc., only the names 
of the channels are provided in most television listings. The 
reason for this is that in some metropolitan areas, such as Los 
Angeles, there may be only one (1) edition of television guide, 
10 but there may be quite a few cable carriers, each of which may 
assign HBO or ESPN to different cable channel numbers. In order 
for a compressed code such as the G-code to be applicable to the 
cable channels as published by a wide area television guide 
publication, the following approach can be used. 

15 

First, all the cable channels would be permanently assigned 
a unique number, which would be valid across the nation. For 
example, we could assign ESPN to cable channel 1, HBO as cable 
channel 2, SHO as cable channel 3, etc. This assignment would be 
20 published by the television guide publications. 

The video cassette recorder apparatus, such as the remote 
controller, the VCR unit or both, could then be provided with two 
(2) extra modes: "set" and "cable channel". One way of providing 

25 the user interface to these modes would be to provide two (2) 
extra buttons: one called SET and one called GABLE CHANNEL. The 
buttons could be located on the video cassette recorder unit 
itself or located on a remote controller, as shown in FIGs 1, 3 
and 5, where SET is element 168 and CABLE CHANNEL is element 170. 

30 Of course, other user interfaces are possible. 

Next, the television viewer would have to go through a one- 
time "setting" procedure of his VCR for all the cable channels 
that he would likely watch . This " setting" procedure would 
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relate each of the assigned numbers for each cable channel to the 
channel number of the local cable carrier. For example, suppose 
that the local cable carrier uses channel 6 for ESPN, then cable 
channel number 1 could be assigned to ESPN, as shown in the 
5 following table. 

Cable Channel Assigned Channel Number in 

Name Cable Chan. No. the local cable carrier 

10 EPSN 1 6 

HBO 2 24 

SHO 3 23 

15 



DIS 8 25 



20 The user could perform the "setting" procedure by pushing the 
buttons on his remote controller as follows: 

SET 06 CABLE CHANNEL 1 PROGRAM 
SET 24 CABLE CHANNEL 2 PROGRAM 
25 SET 23 CABLE CHANNEL 3 PROGRAM 

SET 25 CABLE CHANNEL 8 PROGRAM 

The "setting" procedure would create a cable channel address 
table 162, which would be loaded into RAM 52 of command 
30 controller 36. For the above example, the cable channel address 
table 162 would have the following information. 

CABLE CHANNEL ADDRESS TABLE 162 
1 6 
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24 
23 



28 



8 25 

After the "setting" procedure is performed, the TV viewer 
can now select cable channels for viewing by the old way: eg. 
pushing the key pad buttons 24 will select HBO. He can also do 
it the new way: eg. by pushing CABLE CHANNEL 2, which will also 
select HBO. The advantage of the new way is that the television 
guide will publish [C2] next to the program description, so the 
viewer will just look up the assigned channel number instead of 
having to remember that HBO is local cable channel 24. When the 
CABLE CHANNEL button is pushed, command controller 36 knows that 
it will look up the local cable channel number in cable channel 
address table 162 to tune the VCR to the correct channel. 

For timer preprogramming and for using the compressed 6- 
code, a way to differentiate between broadcast and cable channels 
is to add an eighth channel bit, which would be set to 0 for 
normal broadcast channels and 1 for cable channels such as HBO. 
This eighth channel bit could be one of the low order bits such 
as the third bit C 3 out of the eight channel bits, so that the 
number of bits to specify popular channels is minimized, whether 
they be normal broadcast or cable channels. For a normal 
broadcast channel, the 7 other bits can be decoded according to 
priority vector c table 124. For a cable channel, the 7 other 
bits can be decoded according to a separate cable channel 
priority vector table 160, which could be stored in ROM 54 of 
microcontroller 36. The cable channel priority vector table can 
be set ahead of time for the entire country or at least for an 
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area covered by a particular wide area television guide 
publication. 

A television guide that carries the compressed code known as 
5 the G-code will now print the cable channel inf ormation as 
follows: 

6:30 pm 

HBO xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx (4679) 
xxxxxx ( program description ) xxxxxxxxxx 
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx 

The [C2] in front of HBO reminds the viewer that he needs only to 
push CABLE CHANNEL 2 to select HBO* The (4679) is the G-code for 
15 this particular program. 

FIG. 8 shows a section of a television guide. The cable 
channels all have an assigned cable channel number 188 after the 
cable channel mnemonic. Other than that the cable channel 
20 information is arranged the same as the broadcast channels with a 
compressed G-code 212 associated with the channel. 

For timer preprogramming/ the viewer need only enter the 
number 4679 according to the unit's G-code entry procedure, eg. 

25 PROG 4679 PROG. The G-code decoder unit will decode this G-code 
into "cable channel 2" and will also signal the command 
controller 36 with a cable channel signal 164 , as shown in FIGs. 
1 and 2, because the extra channel bit will be "1" which 
distinguishes that the G-code is for a cable channel; then, since 

30 the association of "cable channel 2" with channel 24 has been 
established earlier in the "setting" procedure, the command 
controller, if it has received a cable channel signal, will 
immediately look up 2 in the cable channel address table 162 to 
translate it to cable channel 24, which will be used as the 

29 



[C2] 

10 
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recording channel at the appropriate time. By associating the G- 
code with the assigned cable channel number rather than the local 
cable channel number, the G-code for that program will be valid 
in the whole local area, which may have many different cable 
5 carriers each of which may have different local cable channel 
numbers . 

To include the cable channel compressed G-code feature, the 
decoding and encoding algorithms are as shown in FXGs 9 and 10, 

10 respectively. The encoding should be explained first before the 
decoding* The primary change in FIG* 10 from FIG. 7 is that a 
cable channel priority vector table 160 has been added and is 
used in look up priority step 180 if a cable channel is being 
encoded. Also if a cable channel is being encoded then the 

15 cable channel bit is added in the correct bit position in the 
convert C p D p T p Lp to binary numbers step 182. This could be bit 
C 3 , as discussed before. The bit hierarchy key could be 
determined as before to compress the number of bits in the most 
popular programs; however, it needs to be 23 bits long to 

20 accommodate the cable channel bit* The maximum compressed G-code 
length could still be 7 digits, because 2 23 = 8,388,608. 

The decoding is shown in FIG. 9 and is just the reverse of 
the encoding process. After step 108, test cable channel bit 174 

25 is added and effectively tests the cable channel bit to determine 
if it is a "1". If so then the command controller 36 is signaled 
via cable channel signal 164 of FIGs. 1 and 2 that the CDTL 118 
that will be sent to it from G-code decoder 38 is for a cable 
channel. Then the command controller knows to look up the local 

30 cable carrier channel number based on the assigned cable channel 
number. in step 176 of FIG. 9, the priority vector tables 
including the cable channel priority vector table 160 are used to 
look up the CDTL 118 information. 
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An alternate to having the command controller receive a 
cable channel signal 164 is for the G-code decoder to perform all 
of the decoding including the conversion from assigned cable 
channel number to local cable carrier number. This would be the 
5 case for the remote controller implementation of FIG. 3. FIG. 11 
shows the implementation of the entire decode algorithm if this 
step is included. All that needs to added is convert assigned 
channel to local cable carrier channel step 166, which performs a 
lookup in cable channel address table 162, if the cable channel 
10 bit indicates that a cable channel is involved. Step 166 
effectively replaces step 174 in FIG. 9. 

Another issue that needs addressing is the number of 
programs that can be preprogrammed. Since the G-code greatly 

15 simplifies the process of entering programs, it is likely that 
the user will quickly learn and want to enter a large number of 
programs; however, some existing VCRs can only store up to four 
(4) programs, while some can store as many as eight. Thus, the 
user may get easily frustrated by the programming limitations of 

20 the VCR. 

One approach to this problem, is to perform the compressed 
G-code decoding in the remote controller and provide enough 
memory there to store a large number of programs, eg. 20 or 40. 

25 The remote controller would have the capability of transferring 
periodically several of these stored programs at a time to the 
VCR main unit. To provide this capability, extra memory called 
stack memory 76 is required inside the remote unit, as shown in 
Fig. 12, which other than that is identical to FIG. 4. Stack 

30 memory 76 can be implemented with a random access memory, which 
may in fact reside in the microcontroller itself, such as RAM 62. 

The stack memory 76 is where new entry, insertion & deletion 
of timer preprogramming information is carried out. It is also 
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where editing takes place. The top memory locations of the 
stack, for example the first 4 locations, correspond exactly to 
the available timer preprogramming memory in the VCR main unit. 
Whenever the top o f the stack memory is changed , the new 
5 information will be sent over to the VCR main unit to update it. 

FIG. 13 shows the sequence of events when the user enters a 
G-code program on the keypad of the remote controller. For 
illustration purposes, suppose the VCR main unit can only handle 

10 four (4) programs. Suppose also that the stack memory capacity 
is 20 timer preprograms. Referring to the flow chart in FIG. 13, 
when the user enters a G-code in step 230, the microcontroller 60 
first decodes it into the CDTL information in step 234 and 
displays it on the display unit with the additional word 

15 "entered" also displayed. The microcontroller then enters the 
decoded program into the stack memory in step 236. 

If this is the first program entered, it is placed at the 
top location of the stack memory. If there are already programs 

20 in the stack memory , the newly entered program will first be 
provisionally placed at the bottom of the stack memory. The 
stack memory will then be sorted into the correct temporal order 
in step 240, so that the earliest program in time will appear in 
the top location and the last program in time will be at the 

25 bottom. Notice that the nature of the temporally sorted stack 
memory is such that if stack memory location n is altered, then 
all the locations below it will be altered. 

For example, suppose the stack memory has six (6) entries 
30 already temporally ordered, and a new entry is entered whose 
temporal ordering places it in location 3 (1 being the top 
location) . If this entry is placed into location 3 , information 
which was in location 3, 4, 5, 6 will be shifted to locations 4, 
5, 6, and 7. Locations 1 and 2 will remain unchanged. 
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entries over to "replenish" the VCR main unit (if the stack has 
more than 4 entries) . 

The real time clock 85 in the remote controller unit is 
monitored by the microcontroller to determine when the programs 
in the main unit have been used up. Referring to the flow chart 
in FIG, 14 , the microcontroller periodically checks the clock and 
the times for the programs at the top of the stack in step 250 
(say the first 4 entries) , which are identical to the VCR's main 
unit's menu. If on one of the periodic checks, it is determined 
that the recording of the main unit's menu is complete, then if 
there are more entries in the stack, which is tested in step 252, 
the display- unit will be set to a blinking mode or display a 
blinking message in step 258 to alert the user to send more 
programs. Next time the user picks up the remote unit, the 
blinking will remind him that the VCR main unit's program menu 
has been completed and it is time to replenish the VCR main unit 
with program entries stored in the remote. The user simply picks 
up the remote and points it towards the VCR main unit and presses 
"ENTER". This will "pop" the top of the stack memory in step 
260, ie. pop all the entries in the stack up by four locations. 
The microcontroller will then send the new "top of the stack" 
(ie. top 4 entries) over to the VCR main unit in step 262. This 
process will repeat until the whole stack has been emptied. 

It is thought that the apparatus and method for using 
encoded video recorder/player timer preprogramming information 
of the present invention and many of its attendant advantages 
will be understood from the foregoing description and it will be 
apparent that various changes may be made in the form, 
construction and arrangement of the parts thereof without 
departing from the spirit and scope of the invention or 
sacrificing all of its material advantages, the form hereinbefore 
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described being merely a preferred or exemplary embodiment 
thereof. 
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We claim: 

1. A recorder using compressed codes for recorder timer 
preprogramming that comprises: 

means for entering and transmitting a compressed code having 
at least one digit; 

means for receiving a command signal coupled to said means 
for entering and transmitting a compressed code having at least 
one digit; 

means for command control for interpreting that a received 
signal is a compressed code having at least one digit and for 
controlling a recorder, electrically coupled to said means for 
receiving a command signal; 

a means for keeping time electrically coupled to said means 
for command control; 

means for decoding a compressed code having at least one 
digit into channel, date f time and length * information 
electrically coupled to said means for command control; 

means for recording and playback; 

means for turning said means for recording and playback on 
and off in response to said date, time and length information; 
and 

means for tuning channels electrically coupled to a signal 
input and to said means for recording and playback and to said 
means for command control and responsive to said channel 
information. 

2. The recorder using compressed codes for recorder timer 
preprogramming of claim 1 wherein: 
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said means for keeping time is electrically coupled to said 
means for decoding a compressed code having at least one digit 
into channel, date, time and length information; and 

wherein the decoding of a compressed code by said means for 
5 decoding a compressed code into channel, date, time and length 
information is a function of the time of said means for keeping 
time « 

3. The recorder using compressed codes for recorder timer 
10 preprogramming of claim 2 which further comprises: 

means coupled to said means for command control for daily, 
using said channel, date, time and length (CDTL) information 
decoded from said compressed code having at least one digit 
15 wherein the start date is the date specified in said channel, 
date, time and length (CDTL) information for recording a program 
daily. 

4. The recorder using compressed codes for recorder timer 
20 preprogramming of claim 2 which further comprises: 

means coupled to said means for command control for weekly 
using said channel, date, time and length (CDTL) information 
decoded from said compressed code having at least one digit 
25 wherein the start date is the date specified in said channel, 
date, time and length (CDTL) information for recording a program 
weekly . 

5. The recorder using compressed codes for recorder timer 
30 preprogramming of claim 2 wherein said means for entering and 

transmitting a compressed code having at least one digit 
comprises: 
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means for remote control having . a signal transmit means 
coupled to said means for command control receiver; and 

means for entering a compressed code having at least one - 
digit electrically coupled to said means for remote control. 

5 

6. The apparatus for using encoded video recorder/player timer 
preprogramming information of claim 2 wherein said means for 
entering and transmitting a compressed code comprises: 

10 means for manual control electrically coupled to said means 

for a command signal receiver; and 

means for compressed code entry means electrically coupled 
to said means for manual control* 

15 7. A recorder using compressed codes for recorder timer 
preprogramming that comprises: 

means for remote control having a means for transmitting 
signals ; 

20 means for entering a compressed code having at least one 

digit electrically coupled to said means for remote control? 

means for decoding a compressed code having at least one 
digit into channel, date, time and length information 
electrically coupled to said means for remote control; 

25 means for receiving a command signal coupled to said means 

for transmitting signals on said means for remote control; 

means for command control for controlling a recorder 
electrically coupled to said means for receiving a command 
signal; 

30 a first means for keeping time electrically- "coupled to said 

means for command control; 

means for recording and playback; 

means for turning said means for recording and playback on 
and off in response to said date, time and length information 
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sent from said means for remote control to said means for command 
control; and 

means for tuning channels electrically coupled to a signal 
input and to said means for recording and playback and to said 
5 means for command control and responsive to said channel 
information sent from said means for remote control to said means 
for command control. 

8. The recorder using compressed codes for recorder timer 
10 preprogramming of claim 7 that further comprises: 

a second means for keeping time electrically coupled to said 
means for decoding a compressed code having at least one digit 
into channel, date, time and length information; 
15 wherein the decoding of a compressed code by said means for 

decoding a compressed code into channel, date, time and length 
information is a function of the time of said second means for 
keeping time. 

20 9 . The recorder using compressed codes for recorder timer 
preprogramming of claim 8 which further comprises: 

means coupled to said command controller for daily using 
said channel, date, time and length (CDTL) information decoded 
25 from said compressed code having at least one digit wherein the 
start date is the date specified in said channel, date, time arid 
length (CDTL) information for recording a program daily. 

10. The recorder using compressed codes for recorder timer 
30 preprogramming of claim 8 which further comprises: 

means coupled to said command controller for weekly using 
said channel, date, time and length (CDTL) information decoded 
from said compressed code having at least, one digit wherein the 
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start date is the date specified in said channel, date, time and 
length (CDTL) information for recording a program weekly. 

11. A recorder using compressed codes for recorder timer 
5 preprogramming that comprises: 

means for universal remote control having a means for 
transmitting signals and a means for receiving signals; 

a learn switch electrically coupled to said means for 
10 universal remote control wherein when said learn switch is "ON" 
said means for universal remote control can learn another remote 
controller functions via said means for receiving signals; 

means entering a compressed code having at least one digit 
electrically coupled to said means for universal remote control; 
15 means for decoding a compressed code having at least one 

digit into channel, date, time and length information 
electrically coupled to said means for universal remote control; 

means for receiving a command signal coupled to said means 
for transmitting signals on said universal remote control; 
20 means for command control for controlling a recorder 

electrically coupled to said means for receiving a command 
signal ? 

a first means for keeping time electrically coupled to said 
means for command control; 
25 means for recording and playback; 

means for turning said means for recording and playback on 
and off in response to said date, time and length information 
sent from said means for remote control to said means for command 
control; and 

30 means for tuning channels electrically coupled to a signal 

input and to said means for recording and playback and to said 
means for command control and responsive to said channel 
information sent from said means for remote control to said means 
"for command control. 
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12. The recorder using compressed codes for recorder timer 
preprogramming of claim 11 that further comprises: 

5 a second means for keeping time electrically coupled to said 

means for decoding a compressed code having at least one digit 
into channel, date, time and length information; and 

wherein the decoding of a compressed code by said means for 
decoding a compressed code into channel, date, time and length 
10 information is a function of the time of said second means for 
keeping time. 

13. The recorder using compressed codes for recorder timer 
preprogramming of claim 12 which further comprises: 

means coupled to said command controller for daily using 
said channel, date, time and length (CDTL) information decoded 
from said compressed code having at least one digit wherein the 
start date is the date specified in said channel, date, time and 
length (CDTL) information for recording a program daily. 

14. The recorder using compressed codes for recorder timer 
preprogramming of claim 12 which further comprises: 

means coupled to said command controller for weekly using 
said channel, date, time and length (CDTL) information decoded 
from said compressed code having at least one digit wherein the 
start date is the date specified in said channel, date, time and 
length (CDTL) information for recording a program weekly. 

15. A method for using compressed codes for recorder timer 
preprogramming comprising the steps of: 
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providing a program guide wherein each program description 
has a compressed code of at least one digit associated with said 
program description representing the channel, date, time and 
length of the program; 
5 providing a means for entering a compressed code of at least 

one digit to perform timer preprogramming for each selected 
program; . 

providing a means for decoding a compressed code; 
decoding said compressed code of at least one digit into 
10 channel, date, time and length information; 

providing a clock means for keeping time; 

comparing said date, time and length information to said 
clock means; 

providing a means for tuning channels; 
15 tuning said means for tuning channels to the channel 

indicated by said channel information when said clock means 
compares with said date and time information; 

providing a means for recording and playback; 

turning said means for record and playback on for record 
20 when said clock means compares with said date and time 
inf ormation ; and 

turning said means for recording and playback means off for 
record when said length information matches time of recording on 
said clock means. 

25 

16. The method for using compressed codes for recorder timer 
preprogramming of claim 15 wherein the step of decoding said 
compressed code of at least one digit into channel, date, time 
and length information further comprises the steps of: 

30 

converting said compressed code of at least one digit into a 
compressed code of binary bits; 

providing a bit hierarchy key that specifies the reordering 
of said compressed code of binary bits; 
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reordering all the bits in said compressed code of binary 
bits according to said bit hierarchy key to obtain a reordered 
binary compressed code; 

separating said reordered binary compressed code into binary 
5 channel, date, time and length priority indices; 

providing priority vectors for channel, date r time and 
length; and 

using said channel, date, time and length priority indices 
to lookup channel, date, time and length information from said 
10 priority vectors for channel, date, time and length, 
respectively . 

17. The method for using compressed codes for recorder timer 
preprogramming of claim 16 wherein the step of decoding said 

15 compressed code of at least one digit into channel date time and 
length information further comprises the steps of: 

providing a plurality of bit hierarchy keys; and 
selecting one of said plurality of bit hierarchy keys for 
20 use as a function of the time of said clock means. 

18. The method for using compressed codes for recorder timer 
preprogramming of claim 16 wherein the step of decoding said 
compressed code of at least one digit into channel date time and 

25 length information further comprises the steps of: 

providing multiple sets of priority vectors for channel, 
date, time and length; and 

selecting one of said multiple sets of priority vectors for 
30 channel., date, time and length for use as a function of the time 
of said clock means. 



19. The method for using compressed codes for recorder timer 
preprogramming of claim 16 which further comprises the steps of: 
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providing a means for daily comparing said clock means to 
the channel, time and length information in said channel , date, 
time and length information starting on the date specified in 
5 said channel, date, time and length information; 

tuning said means for tuning channels to the channel 
indicated by said channel information when said clock means 
compares with said time information; 

turning on recording for said means for recording and 
10 playback when said clock means compares with said time 
information; and 

turning off recording for said means for recording and 
playback when said length information matches time of recording 
on said clock means. 

15 

20. The method for using compressed codes for recorder timer 
preprogramming of claim 16 which further comprises the steps of: 

providing a means for comparing weekly said clock means to 
20 the channel, time and length information in said channel, date, 
time and length information starting on the date specified in 
said channel, date, time and length information; 

tuning said means for tuning channels to the channel 
indicated by said channel information when said clock means is 
25 compared weekly and compares with said time information; 

turning on recording for said means for recording and 
playback when said clock means is compared weekly and compares 
with said time information; and 

turning off recording for said means for recording and 
30 playback when said length information matches time of recording 
on said clock means. 
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21. The method of using encoded video recorder/player timer 
preprogramming information of claim 15 wherein the step of 
decoding said compressed code of one to many digits into channel 
date time and length information further comprises the step of: 

periodically using different algorithms for decoding said 
compressed code of one to many digits into channel date time and 
length information. 

22. The method of using encoded video recorder/player timer 
preprogramming information of claim 15 wherein the step of 
decoding said compressed code of one to many digits into channel 
date time arid length information further comprises the steps of: 

converting said compressed code of one to many digits into a 
compressed mixed radix number code; 

providing a hierarchy key that specifies the reordering of 
said compressed mixed radix number code; 

reordering all the numbers in said compressed mixed radix 
code according to said hierarchy key to obtain a reordered 
compressed mixed radix code; 

separating said compressed mixed radix code into channel, 
date, time and length priority indices; 

providing priority vectors for channel, date, time and 

length; and 

using said channel, date, time and length priority indices 
to lookup channel, date, time and length information from said 
priority vectors for channel, date, time and length. 

23. A method of encoding a set of codes to represent a 
multidimensional vector to minimize the length of codes which are 
most often used based oh the relative probabilities of the values 
in each dimension in order to assist in making it easier to 
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select multidimensional vectors for commercial or industrial 
applications- comprising the steps of: 

entering an input value for each dimension of the 
multidimensional vector; 

providing a priority vector table for each dimension of the 
multidimensional vector wherein the priority vector table for 
each dimension lists every possible value in the dimension in the 
order of its relative priority and assigns a unique priority 
number to every possible value; 

performing a table lookup in said priority vector table on 
said input value for each dimension to find its unique priority 
numbers ; 

converting each said unique priority number for said input 
value for each dimension to a binary number and concatenating the 
resulting binary numbers to form one long binary number; 

providing a binary bit hierarchy key arranged in the order 
of highest differential probability to least differential 
probability of the combination of bits representing all the 
dimensions of the multidimensional vector , wherein the 
differential probability is a measure of the relative importance 
of a bit from one dimension over a bit from another dimension in 
minimizing the length of codes which are most often used; 

reordering all bits in said one long binary number according 
to the order of said binary bit hierarchy key to form a 
compressed code; and 

using said compressed code to select multidimensional 
vectors for commercial or industrial applications. 

24. The method of claim 23 wherein the step of reordering all 
bits in said one long binary number according to the order of 
said binary bit hierarchy key further comprises the step of 
converting the resulting binary number to decimal. 
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25. The method of claim 23 wherein the step of providing a 
binary bit hierarchy key arranged in the order of highest 
differential probability to least differential probability of the 
combination of bits representing all the dimensions of the 

5 multidimensional vector, wherein the differential probability is 
a measure of the relative importance of a bit from one dimension 
over a bit from another dimension in minimizing the length of 
codes which are most often used further comprises interchanging 
some of the bits on a periodic basis for security reasons. 

10 

26. The method of claim 23 wherein the step of using the 
resulting compressed code to select multidimensional vectors for 
commercial or industrial applications further .comprises: 

decoding the compressed code into its original input values 
15 for each dimension of the multidimensional vector. 

27. The method of claim 26 wherein the step of decoding the 
compressed code into its original input values for each dimension 
of the multidimensional vector further comprises: 

20 

providing a binary bit hierarchy key arranged in the order 
of highest differential probability to least differential 
probability of the combination of bits representing all the 
dimensions of the multidimensional vector, wherein the 

25 differential probability is a measure of the relative importance 
of a bit from one dimension over a bit from another dimension in 
minimizing the length of codes which are most often used; 

reversing the step of reordering all bits in said one long 
binary number according to the order of said binary bit hierarchy 

30 key; 

grouping the reordered bits into those belonging to each 
dimension and converting the resulting binary numbers to decimal 
priority numbers; 
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providing a priority vector table for each dimension of the 
multidimensional vector wherein the priority vector table for 
each dimension lists every possible value in the dimension in the 
order of its relative priority and assigns a unique priority 
number to every possible value; and 

looking up a value for each dimension of the 
multidimensional vector in each said priority vector table by 
using said decimal priority numbers as an index to each said 
priority vector table. 

28. A method of encoding a set of codes to represent a 
multidimensional vector to minimize the length of codes which are 
most often used based on the relative probabilities of the values 
in each dimension in order to assist in making it easier to 
select multidimensional vectors for commercial or industrial 
applications comprising the steps of: 

entering an input value for each dimension of the 
multidimensional vector; 

providing a priority vector table for each dimension of the 
multidimensional vector wherein the priority vector table for 
each dimension lists every possible value in the dimension in the 
order of its relative priority and assigns a unique priority 
number to every possible value; 

performing a table lookup in said priority vector table on 
said input value for each dimension to find its unique priority 
numbers and concatenating these unique priority numbers into one 
number; and 

using the resulting code to select multidimensional vectors 
for commercial or industrial applications. 

29. A television calendar for combined visual selection of 
programs for direct viewing and for use in automatic recording of 
programs for future viewing, the combination comprising: 
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a day section and positioned in relation therewith an 
associated unique day visual identifier, for each of a plurality 
of calendar days; 

5 a time-of-day section and positioned in relation therewith 

an associated unique time-of-day visual identifier, within each 
day section, for each of a plurality of television program 
starting times; 

a plurality of unique channel visual indications and 
10 corresponding to each such channel visual indication, a 
descriptive program indication within each time-of-day section 
for each television program that starts at the time of such time- 
of-day section; and 

an additional unique coded indication for the start of each 
15 said television program positioned in a predetermined relation to 
each said channel visual indication, the coded indication 
representing the channel corresponding to said channel visual 
indication for said television program, the time of day 
corresponding to said time-of-day visual indication for said 
20 time-of-day section for said television program, the calendar day 
corresponding said day visual identifier for said day section in 
which said television program appears, and the length of time for 
said television program. 

25 30. A television calendar on a display medium for combined 
visual selection of programs for direct viewing and for 
automatically programming a video recorder for time-shifted 
viewing, the combination comprising: 

30 a day-of-year section for each of a plurality of calendar 

days, the day-of-year sections being ordered sequentially on the 
display medium by calendar day and each of the day-of-year 
sections being positioned in relation to a unique day-of-year 
visual indicator on the display medium; 
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a time-of day section for each of a plurality of television 
program starting times within a calendar day, the time-of-day 
sections being ordered sequentially on the display medium by time 
within each day-of-year section and each of the time-of-day 
sections being positioned in relation to a unique time-of-day 
visual indicator on the display medium; 

a plurality of unique channel indications on the display 
medium within each of the time-of-day sections , each channel 
indication further being positioned corresponding to a 
descriptive program indication for each television program that 
begins at the starting time indicated by the time-of-day section; 
and 

a plurality of unique coded indications , each corresponding 
to and positioned on the display medium in relation to a unique 
channel indication and its corresponding descriptive program 
indication , each of the unique coded indications representing a 
unique television channel represented by the channel indications, 
the time of day represented by the time-of-day indications for 
the corresponding time-of-day section, the calendar day 
represented by the day-of-year indications for the corresponding 
day-of-year section, and the duration of the corresponding 
television program. 

31. A method of creating a television calendar for combined 
visual selection of programs for direct viewing and for use in 
automatic recording of programs for future viewing, comprising 
the steps of: 

providing a coded date visual identifier representing the 
date on which the television program will be broadcasted; 

providing a coded time-of-day visual identifier representing 
the time that the program will be broadcasted; 

providing a coded channel visual identifier representing the 
channel of the program; and 
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providing a coded length visual identifier representing the 
duration of the program. 

32. A system for the automatic recording of a television program 
5 on a video recorder comprising: 

a television calendar listing television programs by the 
date and time of each program and the television channel on which 
each program is to appear, the calendar having a unique 

10 compressed code indication corresponding to the start of each 
different listed program and representing the date and time the 
program is to start, the channel on which the program will 
appear, and the duration of the program; and 

a controller for the video recorder for receiving 

15 representations of the compressed coded indications and for 
enabling such video recorder to commence recording television 
signals carrying the program on the channel, on the date, at the 
time and terminating after the duration represented by any of 
said compressed coded indications. 



20 



33. The system of claim 32 wherein the controller comprises: 



input for receiving the representation of the compressed 
code indications; 

25 a decoder for decoding the compressed code indications into 

corresponding channel, date, time and duration information; 

a channel selector for selecting the channels identified in 
the compressed code indications decoded by said decoder; and 

an on/off controller for enabling recording by the video 

30 recorder for a television program by activating said channel 
selector to select the corresponding channel as decoded for that 
television program and turning on the recording commencing at a 
date and a time as decoded for the television program and 
terminating recording after the duration decoded for the 
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television program represented by the same compressed coded 
indication that is decoded by the decoder. 

34 . A video cassette recorder controller for automatically 
5 enabling recording by a video cassette recorder of a channel of 

video signals specified by a coded channel signal beginning at 
the time of day specified by a coded time-of-day signal, on the 
calendar day specified by a coded day signal and for the length 
of time specified by a coded length signal, "the improvements 
10 comprising: 

an input for receiving a compressed coded signal 
representative of and compressed in length from, the combination 
of said coded channel, time-of-day, day and length signals; and 
15 a decoder for decoding and expanding said compressed coded 

signal to said individual coded channel, time-of-day, day and 
length signals for control of such controller.. 

35. The video controller of claim 34 wherein the input and 
20 decoder are an integral part of the controller. 

36. The video controller of claim 34 comprising a remote 
handheld transmitter comprising said input and decoder. 

25 37. The video controller of claim 35 or 36 wherein the input 
comprises a keyboard entry device. 

38. The video controller of claim 35 or 36 wherein the decoder 
comprises a microprocessor. 

30 

39. A method of programming a video cassette recorder controller 
for automatically enabling recording by a video cassette recorder 
of a channel of video signals specified by a coded channel signal 
beginning at the time of day specified by a coded time-of-day 
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signal, on the calendar day specified by a coded day signal and 
for the length of time specified by a coded length signal, the 
steps comprising: 

5 receiving a compressed coded signal representative of and 

compressed in length from, the combination of said coded channel, 
time-of-day, day and length signals; and 

decoding and expanding said compressed coded signal to said 
individual coded channel, time-of-day, day and length signals for 
10 control of such controller. 

40. The method of claim 39 comprising the step of receiving the 
compressed coded signals in the controller. 

15 41. The method of claim 39 comprising the step of receiving the 
compressed coded signal in a remote handheld transmitter. 



42. The method of claim 40 or 41 wherein the step of receiving 
comprises the step of inputting the compressed coded signal 

20 through a keyboard entry device. 

4 3 . The method of claim 40 or 41 wherein the step of decoding 
comprises the step of decoding the compressed coded signal which 
comprises a microprocessor. 

25 

44. An apparatus for decoding television program information, 
including channel, date, time, and length of the program, for 
automatically recording television programs with a television 
said apparatus comprising: 

30 

means for entering encoded data into the apparatus; 
means for decoding said encoded data to determine the date, 
time, channel and length of the program to be recorded; and 
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means for generating control signals from said encoded data 
for control of the video recorder to select the channel and to 
activate and stop the recording of the video recorder. 

45. A method of using a set of codes to represent a 
multidimensional vector to minimize the length of codes which are 
most often used based on the relative probabilities of the values 
in each dimension in order to assist in making it easier to 
select multidimensional vectors for commercial or industrial 
applications comprising the steps of: 

entering an input value for each dimension of the 
multidimensional vector; 

providing a priority vector table for each dimension of the 
multidimensional vector wherein the priority vector table for 
each dimension lists every possible value in the dimension in the 
order of its relative priority and assigns a unique priority 
number to every possible valuer 

performing a table lookup in said priority vector table on 
said input value for each dimension to find its unique priority 
numbers ; 

converting each said unique priority number for said input 
value for each dimension to a number in a fixed or mixed radix 
system and concatenating the restating numbers to form one long 
number; 

providing a hierarchy key arranged in the order of highest 
differential probability to least differential probability of the 
combination of numbers representing all the dimensions of the 
multidimensional vector and all the radix positions within each 
number of fixed or mixed radix, wherein the differential 
probability is a measure of the relative importance of a radix 
position of a number from one dimension over a radix position of 
a number from another dimension in minimizing the length of codes 
which are most often used; 
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reordering all numbers in said one long number according to. 
the order of said hierarchy key to form a compressed code; and 

using said compressed code to select multidimensional 
vectors for commercial or industrial applications. 

46. The method of claim 45 wherein the step of using the 
resulting compressed code to select multidimensional vectors for 
commercial or industrial applications further comprises: 

decoding the compressed code into its original input values 
for each dimension of the multidimensional vector. 

47. The method of claim 46 wherein the step of decoding the 
compressed code into its original input values for each dimension 
of the multidimensional vector further comprises: 

providing a hierarchy key arranged in the order of highest 
differential probability to least differential probability of the 
combination of numbers representing all the dimensions of the 
multidimensional vector and all the radix positions within each 
number of fixed or mixed radix, wherein the differential 
probability is a measure of the relative importance of a radix 
position of a number from one dimension over a radix position of 
a number from another dimension in minimizing the length of codes 
which are most often used; 

reversing the step of reordering all numbers in said one 
long number according to the order of said hierarchy key; 

grouping the reordered numbers into those belonging to each 
dimension to form priority numbers; 

providing a priority vector table for each dimension of the 
multidimensional vector wherein the priority vector table for 
each dimension lists every possible value in the dimension in the 
order of its relative priority and assigns a unique priority 
number to every possible value; and 
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looking up a value for each dimension of the 
multidimensional vector in each said priority vector table by 
using said priority numbers as an index to each said priority 
vector table. 

48. A television calendar of claim 29 , the combination further 
comprising: 

a plurality of unique cable channel visual indications and 
corresponding to each such cable channel visual indication , a 
descriptive program indication within each time-of-day section 
for each cable television program that starts at the time of such 
time-of-day section; and 

an assigned cable channel number positioned in a 
predetermined relation to each said cable channel visual 
indication, the assigned cable channel number representing the 
cable channel corresponding to said cable channel visual 
indication for said cable television program and being valid for 
a wide area spanning multiple local cable carriers. 

49. A television calendar of claim 30 , the combination further 
comprising: 

a plurality of unique cable channel indications on the 
display medium within each of the time-of-day sections, each 
cable channel indication further being positioned corresponding 
to a descriptive program indication for each cable television 
program that begins at the starting time indicated by the time- 
of-day section; and 

a plurality of assigned cable channel numbers, each 
corresponding to and positioned on the display medium in relation 
to a unique cable channel indication and its corresponding 
descriptive program indication, each of the assigned cable 
channel numbers representing a unique cable television channel 
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represented by the cable channel indications and being valid for 
a wide area spanning multiple local cable carriers. 

50 The method of using encoded video recorder/player timer 
preprogramming information of claim 16 or 22 wherein the step of 
decoding said compressed code of one to many digits into channel 
date time and length information further comprises the step of: 

testing whether said channel information is for an assigned 
cable channel and if so converting said channel information into 
local cable carrier channel information. 

51. The method of controlling a television controller for 
selecting a cable channel for viewing, the steps comprising: 

providing a television calendar with assigned cable channel 
numbers associated with each cable channel; 

providing a television controller having a cable channel 
address table with memory for a set of assigned cable channel 
numbers and a corresponding set of local cable carrier channel 
numbers and having the capability to convert an assigned cable 
channel number into a local cable carrier channel number by using 
said cable channel address table; 

setting up said cable channel address table with said set of 
assigned cable channel numbers and said corresponding set of 
local cable carrier channel numbers; 

entering an assigned cable channel number corresponding to a 
cable channel selected for viewing; and 

conversion of said assigned cable channel number into a 
corresponding local cable carrier channel number by said 
television controller* 

52. The apparatus for using encoded video recorder/player timer 
preprogramming information of claim 1 wherein: 
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said means for decoding a compressed code into channel, 
date, time and length information electrically coupled to said 
means for command control further comprises a means for detecting 
that said channel information corresponds to an assigned cable 
channel number; and 

said means for command control further comprises a means for 
converting an assigned cable channel number into a local cable 
carrier channel number. 

53. The apparatus for using encoded video recorder/player timer 
preprogramming information of claim 7 or 11 wherein said means 
for decoding a compressed code into channel , date, time and 
length information electrically coupled to said means for remote 
control further comprises: 

a means for detecting that said channel information 
corresponds to an assigned cable channel number; and 

a means for converting an assigned cable channel number into 
a local cable carrier channel number. 

54. The apparatus for using encoded video recorder/player timer 
preprogramming information for a recorder of claim 7 or 11 
further comprises: 

a stack memory coupled to said means for decoding a 
compressed code for storing a plurality of programs consisting of 
channel, date, time and length information for timer 
preprogramming; and 

a second means for keeping time electrically coupled to said 
means for decoding a compressed code into channel, date, time and 
length information. 
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55. The method of permitting a large number of programs to be 
timer preprogrammed for recording by a video cassette recorder 
for time shifted viewing where the video cassetter recorder can 
store only N timer preprogrammed programs, the steps comprising: 
providing a remote controller having a means for keeping 

time; 

entering into said remote controller compressed codes, each 
representative of, and compressed in length from, the combination 
of channel, time-of-day, day and length information for a 
program; and 

decoding each compressed code to channel, time-of-day, day 
and length information; 
providing a memory; 

entering each said channel, time-of-day, day and length 
information into said memory; 

reordering said channel, time-of-day, day and length 
information in said memory into temporal order; and 

testing whether first N entries in said memory have changed 
and if yes, sending changed entries in first N entries to said 
video cassette recorder - 

56. The method of permitting a large number of programs to be 
timer preprogrammed of claim 55, the steps further comprising: 

periodically checking whether stop time of Nth entry of said 
first N entries in memory has passed; and 

if stop time of Nth entry has passed and number of entries 
in memory is greater than N, then turning on a means for alerting 
a user to activate remote controller to send more programs to 
said video cassette recorder and once remote controller is 
activated, setting next N entries in said memory to be the first 
N entries in said memory and sending said first N entries to said 
video cassette recorder and turning off said means for alerting a 
user. 
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57, An apparatus for using encoded video recorder/player timer 
preprogramming information for a recorder that comprises: 

means for remote control having a means for transmitting 
signals; 

means for compressed code entry electrically coupled to said 
means for remote control; 

means for decoding a compressed code into channel, date, 
time and length information electrically coupled to said means 
for remote control; 

means for storing said channel r date, time and length 
information in said remote control; 

a means for keeping time electrically coupled to said means 
for remote control r 

means for command control electrically coupled to said means 
for remote control; and 

wherein said means for command control compares the stored 
date, time and length information to said means for keeping track 
of time and sends at the appropriate time start record and stop 
record commands and channel select commands to a VCR unit via 
said transmit signals from said means for remote control. 

58. The apparatus for using encoded video recorder/player timer 
preprogramming information for a recorder of claim 57 that 
further comprises: 

means for storing a plurality of sets of transmit signals 
for different VCR models commands electrically coupled to said 
means for remote control ; and 

means for selecting for a particular VCR model a set of 
transmit signals for sending commands. 
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59. The apparatus for using encoded video recorder/player timer 
preprogramming information for a recorder of claim 57 wherein: 

said means for remote control is a universal remote 
controller and can learn a set of transmit signals for sending 
commands to a particular VCR. 
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